package com.zmn.oms.services.interfaces.perf;


import com.zmn.oms.model.entity.perf.PerfFact;
import com.zmn.oms.model.entity.perf.PerfFactQuery;

import java.util.List;

/**
 * 工单绩效相关-带时间纬度的事实表(PerfFact)表数据库服务层
 *
 * @author hankangshuai
 * @since 2019-09-18 15:42:22
 */
public interface PerfFactService {

    /**
     * 通过主键查询单条数据
     *
     * @param factId 主键
     * @return 实例对象
     */
    PerfFact findByKey(Integer factId);

    /**
     * 分页条件查询
     *
     * @param perfFactQuery 查询对象
     * @return 对象列表
     */
    List<PerfFact> listPageByQuery(PerfFactQuery perfFactQuery);


    /**
     * 条件查询
     *
     * @param perfFactQuery 查询对象
     * @return 对象列表
     */
    List<PerfFact> listByQuery(PerfFactQuery perfFactQuery);

    /**
     * 条件计数
     *
     * @param perfFactQuery 查询对象
     * @return 影响行数
     */
    int countByQuery(PerfFactQuery perfFactQuery);

    /**
     * 通过主键删除数据
     *
     * @param factId 主键
     * @return 影响行数
     */
    int deleteByKey(Integer factId);

    /**
     * 批量插入，如果重复则更新
     *
     * @param perfFacts 插入集合
     * @return 影响行数
     */
    Integer insertOnDuplicateUpdateBatch(List<PerfFact> perfFacts);
}